import java.util.HashMap;

class Solution {
    public int totalFruit(int[] fruits) {
        HashMap<Integer,Integer> map = new HashMap<>();
        int left = 0,right = 0,len = 0,kinds = 0;
        while(right < fruits.length) {
            map.put(fruits[right],map.getOrDefault(fruits[right],0) + 1);
            while(map.size() > 2) {
                map.put(fruits[left],map.get(fruits[left])-1);
                if(map.get(fruits[left]) == 0) {
                    map.remove(fruits[left]);
                }
                left++;
            }
            len = Math.max(len,right - left + 1);
            right++;
        }
        return len;
    }
}